import {createApp} from 'vue'
import Cookies from 'js-cookie'
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import locale from 'element-plus/es/locale/lang/zh-cn'
import '@/assets/styles/index.scss' // global css
import App from './App'
import store from './store'
import router from './router'
import directive from './directive' // directive
// 注册指令
import plugins from './plugins' // plugins
import {download} from '@/utils/request'
// svg图标
import 'virtual:svg-icons-register'
import SvgIcon from '@/components/SvgIcon'
import elementIcons from '@/components/SvgIcon/svgicon'
import './permission' // permission control
import {useDict} from '@/utils/dict'
import {
	parseTime,
	resetForm,
	addDateRange,
	handleTree,
	selectDictLabel,
	selectDictLabels
} from '@/utils/ruoyi'
// 分页组件
import Pagination from '@/components/Pagination'
// 自定义表格工具组件
import RightToolbar from '@/components/RightToolbar'
// 富文本组件
import Editor from "@/components/Editor"
// 文件上传组件
import FileUpload from "@/components/FileUpload"
// 图片上传组件
import ImageUpload from "@/components/ImageUpload"
// 图片预览组件
import ImagePreview from "@/components/ImagePreview"
// 自定义树选择组件
import TreeSelect from '@/components/TreeSelect'
// 字典标签组件
import DictTag from '@/components/DictTag'
import UserSelect from '@/components/EbComponent/Selector/UserSelect/UserSelect'
import DeptSelect from "@/components/EbComponent/Selector/DeptSelect/DeptSelect";
import RoleSelect from "@/components/EbComponent/Selector/RoleSelect/RoleSelect";
import RemindCatSelect from "@/components/EbComponent/Selector/RemindCatSelect/RemindCatSelect";
import AccountCatSelect from "@/components/EbComponent/Selector/AccountCatSelect/AccountCatSelect";
import NoteCatSelect from "@/components/EbComponent/Selector/NoteCatSelect/NoteCatSelect";
import SysNoteCatSelect from "@/components/EbComponent/Selector/NoteCatSelect/SysNoteCatSelect";
import SysAccountCatSelect from "@/components/EbComponent/Selector/AccountCatSelect/SysAccountCatSelect";
import SysRemindCatSelect from "@/components/EbComponent/Selector/RemindCatSelect/SysRemindCatSelect";
import CustomSelect from "@/components/EbComponent/Selector/CustomSelect/CustomSelect";
import EbImageUpload from "@/components/EbComponent/ImageUpload/EbImageUpload";
import EbMultiImageUpload from "@/components/EbComponent/ImageUpload/EbMultiImageUpload";
import EbIconUpload from "@/components/EbComponent/ImageUpload/EbIconUpload";
import EbImagePreview from "@/components/EbComponent/ImagePreview/EbImagePreview";
import AccountCatTreeSelect from "@/components/EbComponent/Selector/AccountCatSelect/AccountCatTreeSelect";
import FileSizeColumn from "@/components/EbComponent/TableColumn/FileSizeColumn";
import IconSelect from "@/components/EbComponent/Selector/IconSelect/IconSelect.vue";
import IconColumn from "@/components/EbComponent/TableColumn/IconColumn.vue";
import PageTpl from "@/components/EbComponent/PageTpl/PageTpl.vue";
import UserSelectMultiple from "@/components/EbComponent/Selector/UserSelect/UserSelectMultiple";
import RoleSelectMultiple from "@/components/EbComponent/Selector/RoleSelect/RoleSelectMultiple";
import FcSelect from "@/views/flow/formCompoents/FcSelect";
import FcRadio from "@/views/flow/formCompoents/FcRadio";
import FcAmount from "@/views/flow/formCompoents/FcAmount";
import FcInput from "@/views/flow/formCompoents/FcInput";
import FcDatePicker from "@/views/flow/formCompoents/FcDatePicker";
import FcUserSelect from "@/views/flow/formCompoents/FcUserSelect";
import FcUpload from "@/views/flow/formCompoents/FcUpload";
import FcTimePicker from "@/views/flow/formCompoents/FcTimePicker";
import FcInputNumber from "@/views/flow/formCompoents/FcInputNumber";
import FcCheckBox from "@/views/flow/formCompoents/FcCheckBox";
import FcDeptSelect from "@/views/flow/formCompoents/FcDeptSelect";
import FcRoleSelect from "@/views/flow/formCompoents/FcRoleSelect";
import FcTargetDeptSelect from "@/views/flow/formCompoents/FcTargetDeptSelect";
import FcLiableUserSelect from "@/views/flow/formCompoents/FcLiableUserSelect";
import EbAvatar from "@/components/EbComponent/Avatar";
import TaskStatusTag from "@/components/EbComponent/TaskStatusTag";
import {G} from "@/views/flow/globalVar.js";
const app = createApp(App)
// 全局方法挂载
app.config.globalProperties.useDict = useDict
app.config.globalProperties.download = download
app.config.globalProperties.parseTime = parseTime
app.config.globalProperties.resetForm = resetForm
app.config.globalProperties.handleTree = handleTree
app.config.globalProperties.addDateRange = addDateRange
app.config.globalProperties.selectDictLabel = selectDictLabel
app.config.globalProperties.selectDictLabels = selectDictLabels
app.config.globalProperties.G = G
// 全局组件挂载
app.component('DictTag',
	DictTag)
app.component('EbAvatar',
	EbAvatar)
app.component('TaskStatusTag',
	TaskStatusTag)
app.component('FcInput',
	FcInput)
app.component('Pagination',
	Pagination)
app.component('TreeSelect',
	TreeSelect)
app.component('FileUpload',
	FileUpload)
app.component('ImageUpload',
	ImageUpload)
app.component('ImagePreview',
	ImagePreview)
app.component('RightToolbar',
	RightToolbar)
app.component('Editor',
	Editor)
app.component('UserSelect',
	UserSelect)
app.component('DeptSelect',
	DeptSelect)
app.component('RoleSelect',
	RoleSelect)
app.component('RemindCatSelect',
	RemindCatSelect)
app.component('AccountCatSelect',
	AccountCatSelect)
app.component('NoteCatSelect',
	NoteCatSelect)
app.component('SysNoteCatSelect',
	SysNoteCatSelect)
app.component('SysAccountCatSelect',
	SysAccountCatSelect)
app.component('SysRemindCatSelect',
	SysRemindCatSelect)
app.component('CustomSelect',
	CustomSelect)
app.component('EbImageUpload',
	EbImageUpload)
app.component('EbMultiImageUpload',
	EbMultiImageUpload)
app.component('EbIconUpload',
	EbIconUpload)
app.component('EbImagePreview',
	EbImagePreview)
app.component('AccountCatTreeSelect',
	AccountCatTreeSelect)
app.component('FileSizeColumn',
	FileSizeColumn)
app.component('IconSelect',
	IconSelect)
app.component('PageTpl',
	PageTpl)
app.component('svg-icon',
	SvgIcon)
app.component('IconColumn',
	IconColumn)
app.component('UserSelectMultiple',
	UserSelectMultiple)
app.component('RoleSelectMultiple',
	RoleSelectMultiple)
app.component('FcSelect',
	FcSelect)
app.component('FcRadio',
	FcRadio)
app.component('FcAmount',
	FcAmount)
app.component('FcDatePicker',
	FcDatePicker)
app.component('FcUserSelect',
	FcUserSelect)
app.component('FcUpload',
	FcUpload)
app.component('FcTimePicker',
	FcTimePicker)
app.component('FcInputNumber',
	FcInputNumber)
app.component('FcCheckBox',
	FcCheckBox)
app.component('FcDeptSelect',
	FcDeptSelect)
app.component('FcTargetDeptSelect',
	FcTargetDeptSelect)
app.component('FcLiableUserSelect',
	FcLiableUserSelect)
app.component('FcRoleSelect',
	FcRoleSelect)
app.use(router)
app.use(store)
app.use(plugins)
app.use(elementIcons)

directive(app)
// 使用element-plus 并且设置全局的大小
app.use(ElementPlus,
	{
		locale: locale, // 支持 large、default、small
		size: Cookies.get('size') || 'default'
	})
app.mount('#app')
